草庐IT

【云原生】2.3 Kubernetes 核心实战(上)

全部标签

go - 从 Mutating Admission Controller 中创建一个新的 Kubernetes 对象

MutatingAdmissionController可以通过连接到api-server来更新/创建另一个对象吗?我看到我们可以使用JSONPatch通过AdmissionReview改变入站对象,但我可以扩展它来创建一个完全不同的对象吗?谢谢!!-斯雷尼 最佳答案 您可以创建一个mutatingwebhookconfigurations,它基本上将服务Hook到mutatingadmissioncontroller。这就是istio向所有启用了istio注入(inject)的pod注入(inject)sidecar代理的方式。可以

go - golang在kubernetes上创建监视程序/ Controller ,以将sidecar容器附加到具有PVC附件的任何pod/部署中

我是个新手,想把上面的事情做完。最简单的方法是什么?我要找的是:1-部署观察者2-更新/删除/添加部署时,将附加一个侧车(修补部署)3-控制来自侧车的反馈。任何参考都有帮助 最佳答案 我建议你看看webhooks这样你就不会重新发明轮子了。webhook可用于拦截对api服务器的资源(包括部署)更新/删除/创建请求。然后,可以根据您的目标修改或拒绝这些请求。 关于go-golang在kubernetes上创建监视程序/Controller,以将sidecar容器附加到具有PVC附件的任何

http - Golang for Kubernetes 中的自定义 404 错误页面

我正在尝试为我的Kubernetes集群实现一个自定义的default-http图像。我只有2个要求:任何图片都可以,只要:它在/提供404页面它在/healthz端点上为200人提供服务截至目前,我得到的是:1packagemain23import(4"fmt"5"net/http"6"html/template"7)89funcmain(){10http.HandleFunc("/healthz",healhtzHandler)11http.HandleFunc("/",errorHandler)12http.ListenAndServe(":8000",nil)13}1415fu

go - GDB 中 goroutine 的展开堆栈,用于 golang exe 的核心转储

我需要分析一些用Golang编写的服务器的核心转储文件。但我无法使用GDB展开堆栈信息(甚至一点点有用的信息)。比如我有一个main.go,它的代码是:packagemainfuncmain(){panic("stupid")}然后我使用以下方法获取核心文件:ulimit-cunlimitedGOTRACEBACK=crash./main然后我运行gdbmaincore。在gdb中,如下所示。xxx@ubuntu:/tmp/crash$gdbmaincoreGNUgdb(Ubuntu7.12.50.20170314-0ubuntu1.1)7.12.50.20170314-gitCopy

go - 使用 Kubernetes 的 Go 客户端列出 Traefik 入口 Controller

我们有一个小的内部工具使用GoclientforKubernetes列出我们的Kubernetes服务.现在我们已经添加了Traefik以使用入口Controller将我们的服务映射到有意义的dns名称。我们看到有一个ingresslisterextension在Kubernetes的Go客户端中,可用于列出入口Controller。但是,我们无法让它发挥作用。是否有列出入口Controller的任何Go客户端代码片段? 最佳答案 到目前为止你尝试了什么?发布示例有帮助。尝试以下任意示例以帮助您入门://imports//metav

go - 为 Kubernetes go-client 使用 HTTP 代理

我正在使用go-clientforkubernetes来控制我的GKE集群上的部署,但此客户端将在代理后面运行,并且需要通过它发出所有与互联网绑定(bind)的请求。但我似乎无法找到一种方法来配置我的KubeClient以通过代理发出所有http请求。我的代码与此处的示例差别不大-https://github.com/kubernetes/client-go/blob/master/examples/out-of-cluster-client-configuration/main.go 最佳答案 当您使用配置(kubernetes.

go - 将自定义 kubernetes 调度程序部署为 pod

如何将自定义kubernetes调度程序部署为使用golang语言编写的pod? 最佳答案 我相信这是有据可查的heremy-scheduler.yaml类似这样的内容:apiVersion:v1kind:ServiceAccountmetadata:name:my-schedulernamespace:kube-system---kind:ClusterRoleBindingapiVersion:rbac.authorization.k8s.io/v1metadata:name:my-scheduler-as-kube-sched

go - 如何从我的 Controller 文件向本地 Kubernetes 部署的服务提供静态文件?

我已经定义了一个部署文件:---apiVersion:apps/v1kind:Deploymentmetadata:name:{{...}}labels:app.kubernetes.io/name:{{...}}helm.sh/chart:{{...}}app.kubernetes.io/instance:{{.Release.Name}}app.kubernetes.io/managed-by:{{.Release.Service}}spec:...我的服务实现了JWT验证,因此需要一个公钥。我能否以某种方式在部署文件中指定为我的服务提供本地生成的pubkey文件?

web - 通过 websocket 将 kubernetes 日志暴露给浏览器

我正在尝试在kubernetes中使用sidecar模式来创建日志sidecar以公开特定的容器日志。我正在使用kubernetes客户端从kubernetesapi获取日志并通过websocket发送出去。代码如下:funcserveWs(whttp.ResponseWriter,r*http.Request){w.Header().Set("Access-Control-Allow-Origin","*")conn,err:=upgrader.Upgrade(w,r,nil)iferr!=nil{if_,ok:=err.(websocket.HandshakeError);!ok{

go - 为什么kubernetes内部使用字符串指针而不是字符串?

不仅是字符串指针,还有bool指针、int指针等参见:https://github.com/kubernetes/cli-runtime/blob/5c4694c3aa38d6f710b2e3b18598f9d83f1aae3b/pkg/genericclioptions/config_flags.go#L322-L336golang似乎无法从ConstantPool之类的东西中获益。语言packagemainimport("fmt")funcStringPtr(sstring)*string{return&s}funcmain(){fmt.Println(StringPtr(""))